# Xilinx Zynq FPGA, TI DSP, MCU 기반의 프로그래밍 및 회로 설계 전문가 과정

강사 – Innova Lee(이상훈)

gcccompil3r@gmail.com

학생 - hoseong Lee(이호성)

hslee00001@naver.com

## Cortex-R5F Hercules safety MCU - boot code 분석

## 1 c\_int00() -> systemInit() -> setupFlash

```
void setupFlash(void)
/* USER CODE BEGIN (6) */
/* USER CODE END */
    /** - Setup flash read mode, address wait states and data wait states */
   flashWREG->FRDCNTL = 0x00000000U
                      | (uint32)((uint32)3U << 8U)
                        3U;
    /** - Setup flash access wait states for bank 7 */
    FSM WR ENA HL
                  = 0x5U;
    EEPROM_CONFIG_HL = 0 \times 000000002U
                    | (uint32)((uint32)9U << 16U) ;
/* USER CODE BEGIN (7) */
/* USER CODE END */
    /** - Disable write access to flash state machine registers */
   FSM WR ENA HL
                   = 0x2U;
    /** - Setup flash bank power modes */
   flashWREG->FBPWRMODE = 0x000000000U
                         | (uint32)((uint32)SYS_ACTIVE << 14U) /* BANK 7 */
                         | (uint32)((uint32)SYS_ACTIVE << 0U); /* BANK 0 */
```

## 1.1 FlashWREG -> FRDCNTL

0011 0000 0011

#### 7.10.1 Flash Read Control Register (FRDCNTL)

FRDCNTL supports prefetch mode. This register controls Flash timings for the main Flash banks. For the equivalent register that controls Flash timings for the EEPROM Emulation Flash bank (bank 7), see Section 7.10.32.

Figure 7-11. Flash Read Control Register (FRDCNTL) (offset = 00h)

|          |     |        | Rese | bryed |          |     |        |        |
|----------|-----|--------|------|-------|----------|-----|--------|--------|
|          |     |        | R    | -0    |          |     |        |        |
| 15       | 12  | 11     | 8    | 7     |          | 2   | 1      | 0      |
| Reserved | đ   | RWAIT  |      |       | Reserved | - 2 | PFUENB | PFUENA |
| R-0      | - 0 | R/WP-1 |      |       | R-0      |     | RWP-1  | RWP-1  |

Table 7-13. Flash Read Control Register (FRDCNTL) Field Descriptions

| Bit        | Field      | Value    | Description                                                                                                                                  |
|------------|------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12      | Reserved   | 0        | Reads return 0. Writes have no effect.                                                                                                       |
| 11-8 RWAIT |            | 0-Fh     | Random/data Read Wait State                                                                                                                  |
|            | 000000     | 55000000 | The random read wait state bits indicate how many wait states are added to a Flash read access. Address wait state is fixed to 1 HCLK cycle. |
|            |            |          | Note: The required wait states for each HCLK frequency can be found in the device-specific data sheet.                                       |
| 7-2        | Reserved   | 0        | Reads return 0. Writes have no effect.                                                                                                       |
| 1          | PFUENB     |          | Prefetch Enable for Port B                                                                                                                   |
|            | 0.08040500 | 0        | Prefetch Mode is disabled.                                                                                                                   |
|            |            | 1        | Prefetch Mode is enabled. (Recommended)                                                                                                      |
| .0         | PFUENA     |          | Prefetch Enable for Port A                                                                                                                   |
|            |            | 0        | Prefetch Mode is disabled.                                                                                                                   |
|            |            | 1        | Prefetch Mode is enabled. (Recommended)                                                                                                      |

→ RWAIT - 주소 wait 상태 (1사이클), FPFUENA: 프레페치 모드 인에이블

## 1.2 FSM\_WR\_ENA\_HL

8bit 0000 0101

EEOROM\_CONFIG\_HL

8bit 0000 0010

#### 7.10.31 FSM Register Write Enable Register (FSM\_WR\_ENA)

Figure 7.41, FSM Register Write Enable Register (FSM WR ENA) (offset = 288h)



Table 7-43. FSM Register Write Enable Register (FSM\_WR\_ENA) Field Descriptions

| Bit  | Field    | Value            | Description                                                                                                                                                                    |
|------|----------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3 | Reserved | 0                | Reads return 0. Writes have no effect.                                                                                                                                         |
| 2-0  | WR_ENA   |                  | FSM Write Enable                                                                                                                                                               |
|      |          | 5h               | This register must contain 5h in order to write to any other register in the range FFF8 7200h to FFF8 72FFh. This is the first register to be written when setting up the FSM. |
|      | 1        | All other values | For all other values, the FSM registers cannot be written.                                                                                                                     |

#### 7.10.32 EEPROM Emulation Configuration Register (EEPROM CONFIG

figure 7-42. EEPROM Emulation Configuration Register (EEPROM\_CONFIG) (offset = 2B8h)



Table 7-44. EPROM Emulation Configuration Register (EEPROM\_CONFIG) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                         |
|-------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20 | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                              |
| 19-16 | EWAIT    |       | EEPROM Walt state Counter Replaces the RWAIT count in the EEPROM register. The same formulas that apply to RWAIT apply to EWAIT in the EEPROM bank. |
| 15-0  | Reserved | 0     | Reads return 0. Writes have no effect.                                                                                                              |

→ FSM\_WR\_ENA 2-0 : 쓰기권한, EEPROM\_CONFIG\_HL 19-16 : 롬 레지스터에 있는 RWAIT count 형식으로 바꿈.

## 1.3 FSM\_WR\_ENA\_HL

8bit 0000 0010

EEOROM\_CONFIG\_HL

8bit 0000 1111

#### 7.10.14 Flash Bank Power Mode Register (FBPWRMODE)

Figure 7-24. Flash Bank Power Mode Register (FBPWRMODE) (offset = 40h)

| 31                |    |    |          |   |          |      |     | 16   |
|-------------------|----|----|----------|---|----------|------|-----|------|
|                   |    |    | Reserved |   |          |      |     |      |
|                   |    |    | R-505h   |   |          |      |     |      |
| 15                | 14 | 13 |          | 4 | 3        | 2    | 1   | 0    |
| BANKPWR7 Reserved |    |    | BANKPWR1 |   | BANKPWR0 |      |     |      |
| RAWP-3h P-3FFh    |    |    |          |   | RW       | P.3h | R/W | P.3h |

R/WP-3h R-3FFh

LEGEND: R/W = Read/Write; R = Read only; WP = Write in Privilege Mode; -n = value after reset

Table 7-26. Flash Bank Power Mode Register (FBPWRMODE) Field Descriptions

| Bit   | Field    | Value | Description                          |  |
|-------|----------|-------|--------------------------------------|--|
| 31-16 | Reserved | 505h  | Do not write to these register bits. |  |
| 15-14 | BANKPWR7 |       | Bank 7 Power Mode.                   |  |
|       |          | 0     | nk sleep mode                        |  |
|       |          | 1h    | Bank standby mode                    |  |
|       |          | 2h    | Reserved                             |  |
|       |          | 3h    | Bank active mode                     |  |
| 13-4  | Reserved | 3FFh  | Do not write to these register bits. |  |
| 3-2   | BANKPWR1 |       | Bank 1 Power Mode.                   |  |
|       |          | 0     | ank sleep mode                       |  |
|       |          | 1h    | Bank standby mode                    |  |
|       |          | 2h    | Reserved                             |  |
|       |          | 3h    | Bank active mode                     |  |
| 1-0   | BANKPWR0 |       | Bank 0 Power Mode.                   |  |
|       |          | 0     | Bank sleep mode                      |  |
|       |          | 1h    | Bank standby mode                    |  |
|       |          | 2h    | Reserved                             |  |
|       |          | 3h    | Bank active mode                     |  |

BANKPWR0 1-0 , BANKWR1 3-2, BANKPWR7 15-14 = 3h, bank 활성화모드

그중 bank 0,1,7 을 파워모드로 설정한다.

## 1 c\_int00() -> systemInit() -> trimLP0

LPOMONCTL 의 하위 16 bit 에 LPO\_TRIM\_VALUE 값 대입함

-0Xf0008 01B4 주소의 레지스터

#### 7.5.2.2 Package and Memory Size

Package and memory size information can be determined from the device-specific datasheet, or can be computed by reading locations in the TI OTP Bank 0 registers.

The package and memory size can be read from TI OTP location F008 015Ch as shown in Figure 7-4 and described in Table 7-6.

Figure 7-4. TI OTP Bank 0 Package and Memory Size Information



LEGEND: R = Read only

Table 7-6. TI OTP Bank 0 Package and Memory Size Information Field Descriptions

| Bit   | Field Description |                               |  |
|-------|-------------------|-------------------------------|--|
| 31-28 | Reserved          | Reserved                      |  |
| 27-16 | PACKAGE           | Count of pins in the package. |  |
| 15-0  | MEMORY_SIZE       | Flash memory size in Kbytes.  |  |

#### 7.5.2.3 LPO Trim and Max HCLK

The HF LPO trim solution, LF LPO trim solution and maximum GCLK1 frequency can be read from TI OTP location F008 01B4h as shown in Figure 7-5 and described in Table 7-7.

Figure 7-5. TI OTP Bank 0 LPO Trim and Max HCLK Information



LEGEND: R = Read only

## → Referance manual

패키지 및 메모리 크기 정보는 장치 별 데이터 시트에서 결정하거나 TI OTP Bank 0 레지스터의 위치를 읽음으로써 계산할 수 있습니다.

패키지 및 메모리 크기는 그림 7-4와 같이 TI OTP 위치 F008 015Ch에서 읽을 수 있으며 표 7-

HF LPO 트림 솔루션, LF LPO 트림 솔루션 및 최대 GCLK1 주파수는 그림 7-5와 표 7-7에서 설명 한대로 TI OTP 위치 F008 01B4h에서 읽을 수 있습니다 imparison clock for the crystal oscillator failure detection circu



Figure 6-4. LPO Block Diagram

s a block diagram of the internal reference oscillator. This is a

→ Datasheet

/\*\* - Wait for until clocks are locked \*/

SYS\_CSVSTAT 뭘하는넘일까

SYS\_CSDIS 는 또 뭘하는넘일까

→ 이두가지로 비활성화, 활성화 되는 클럭을 구별한다. 신호를 안정화 하는데 시간이 걸리 기 때문에 비활성화된 것들이 더 구별하기 쉽다. PLL을 생각해보자

GHVSRC : Clock 들을 어떻게 다룰지

## MRC Instruction

| 명령어  | 동작                      | 어셈블러                                                                                          |  |  |
|------|-------------------------|-----------------------------------------------------------------------------------------------|--|--|
| CDP  | Data operation          | $\label{eq:cond} $$ $$ CDP\{cond\} < cp_num>, , , , {, } $                                    |  |  |
| MRC  | 코프로세스 레지스터의 정보를 ARM레지스  | MRC{cond} <cp_num>, <op1>, <rd>, <crn>, <crm>-{, <op2>}</op2></crm></crn></rd></op1></cp_num> |  |  |
|      | 터로 읽어 온다.               |                                                                                               |  |  |
| MCR  | ARM레지스터의 정보를 코프로세스 레지   | MCR{cond} <cp_num>, <op1>, <rd>, <crn>, <crm>{, <op2>}</op2></crm></crn></rd></op1></cp_num>  |  |  |
|      | 스터로 읽어 온다.              | MCC(COTO) (CP_1001), (CP17, (CD2), (CR117, (CR1117), (OP27)                                   |  |  |
| MRRC | 코프로세스의 정보를 한 쌍의 ARM 레지스 | MRRC{cond} <cp_num>, <op1>, <rd>, <rn>, <crm></crm></rn></rd></op1></cp_num>                  |  |  |
|      | 터들에 전송한다.               |                                                                                               |  |  |
| MCRR | 한 쌍의 ARM 레지스터들의 정보를 코프로 | MCRR{cond} <cp_num>, <op1>, <rd>, <rn>, <crm></crm></rn></rd></op1></cp_num>                  |  |  |
| WOTH | 세스에 전송한다.               |                                                                                               |  |  |
| LDC  | 메모리의 내용을 코프로세스 레지스터에    | LDC{cond} <cp_num>, <crd>, <a_m ode5=""></a_m></crd></cp_num>                                 |  |  |
|      | 저장한다.                   | Ebo (colla) (cp_liam), (orla), (a_modes)                                                      |  |  |
| STC  | 코프로세스 레지스터의 내용을 메모리에    | STC{cond} <cp num="">, <crd>, <a mode5=""></a></crd></cp>                                     |  |  |
| 010  | 저장한다.                   | orotoons, topinship, tonar, talmosos                                                          |  |  |